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ABSTRACT 


This thesis documents an investigation into the use of a computer 
graphics terminal to demonstrate the basic concepts of logical design. 
The areas of computer-assisted instruction, computer graphics, and 
computer-aided design are reviewed prior to the discussion of the crea- 
tion of the INTERACTIVE LOGIC LABORATORY. The program is implemented 
on the Adage Graphics Terminal - 10 (AGT-10) of the Naval Postgraduate 
School Computer Laboratory. 

The main emphasis of the program discussion is on the degree of 
interaction achieved by the program and its possible use as a learning 
aid for students of basic logical design courses. A bipartite graph is 
used to depict the network topology of the logic circuit and the pro- 


tram 1s Quite successiul in the simulation of simple logic circuits. 
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IT. INTRODUCTION 


The value of laboratory work has long been recognized in the 
physical sciences. This most important adjunct to the learning pro- 
cess has both the demonstrative power of presenting classroom concepts 
in a real-world setting as well as allowing the student to learn by 
doing. The experience gained by actual experimentation in the labora- 
tory serves the dual purpose of aiding the learning process and pre- 
paring the student for more rigorous research in later work. 

If Alfred North Whitehead's triad of learning -- a stage of romance, 
a state of precision, a stage of generalization ‘ref. 1! - is accepted, 
the value of the laboratory becomes particularly evident. Thought- 
provoking demonstrations, quite easily presented in the laboratory en- 
vironment, aid immensely in arousing student interest in a topic. The 
ability for precise analysis can be developed by Seadene experimenta- 
tion. Thus leading to a lesser reliance on previously learned specifics, 
a better understanding of the fundamental concept and the ability to 
extrapolate to its implication. 

The value of laboratory experience is also well appreciated in the 
computer sciences as evidenced by the huge investment institutions of 
higher learning have made in computer facilities, both for actual re- 
search and student experimentation. For instance, a dual-processor 
IBM Model 360-67 is installed at the Naval Postgraduate School and this 
facility is utilized for both administrative work as well as extensive 
student and faculty research. Another computer facility implemented at 


the school is a hybrid computer comprised of an XDS-9300 processor 





interfaced with a Comcor CI-5000 analog computer and two Adage (AGT-10) 
Graphics terminals. 

It is impossible for a student at the Naval Postgraduate School to 
complete any of the various courses of study without some degree of 
exposure to one of these computation facilities. Yet, none of these 
computer installations is currently adapted for demonstration and ex- 
perimentation in one of the most basic areas of computer science - 
logical design. Various logic demonstrators have been marketed, in 
fact the Comcor CI-5000 has the capability of being used as a logic 
demonstrator. However, the use of this analog computer for demonstra- 
tion of basic logic design concepts has not been explored due to the 
high cost associated with this implementation. 

The lack of adequate laboratory facilities in a basic logical de- 
Sign course has been apparent to several of the members of the faculty 
at the Naval Postgraduate School. Various approaches to the problem 
have been tried. One professor assigned work on the CDC-160 which in- 
volved using that machine's bit manipulative capabilities, both logical 
and arithmetic, to simulate the various logical operations discussed in 
class. A more extensive effort to implement a meaningful laboratory 
environment for basic logical design consisted of a computer program 
written for the IBM-360 which performed detailed digital machine sim- 
lation at the bit-handling level through control unit level. This 
program ref. 2) was designed to provide the student with an operating 
model of the digital computer capable of both demonstrating computer 
operations and allowing realistic experiments in logical design. 

While the program was a significant improvement over any previous 
laboratory capability, it still was lacking in one important respect -- 


the simulation of a hardware - oriented subject was done using software. 
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The published article recognized "The need for an early course intro- 
ducing the digital computer as a hardware system." [ 2] Yet student 
programming ability in a higher level language was presupposed as a 
requirement for use of the digital machine simulation program. 

With this background it was desired to use existing facilities at 
the Naval Postgraduate School to investigate the implementation of a 
meaningful instructional vehicle for presenting the basic concepts of 
logical design which did not require student programming ability in a 
higher-level language. The criteria by which the effectiveness of the 
implementation would be measured were: 

1) The ability of the program to clearly demonstrate, in familiar 

terms, the basic concepts of logical design. 

2) The ability of the program to allow for student experimentation. 

3) Ability of the program to be utilized by a large number of 

students with minimal instruction and minimal interference with 
other computer users. 

Thus the problem consisted of investigating the various require- 
ments of such a program, determining a suitable set of equipment for 
implementation, and finally creating such a program to demonstrate the 
feasibility of the concept. The intent of this thesis was not to ac- 
tually implement the program at the classroom level, but to investigate 
the construction of such a program in sufficient depth to allow subse- 
quent extension of the concepts considered in the thesis to a general 


classroom implementation. 





IT. BACKGROUND 


A. EDUCATIONAL AIDS 

Many different educational aids have been developed and marketed 
over the past few years. The teaching aids committee of The American 
Society for Ingineering Education (ASEE) was established to review and 
recommend various educational aids to institutions of higher learning. 
In doing so, they established definitions of various types of educa- 
tional aids which were considered pertinent to this study. In particu- 
lar, they subsumed the general term "educational aid" into the more 
comprehensive categories of teaching aids, learning aids and training 
aids. 

Of special importance to this project was the ASEE definition of a 
learning aid as "a device that helps in the understanding of a funda- 
mental of engineering or science and which creates within the student 
a desire to pose and solve a problem by an application of the fundamen- 
tae involved." | 

Of the three categories defined, the committee stressed most heavily 
the importance of learning aids in the educational process, stating in 
part: 

"The old adage, 'Experience is the best teacher' might be rephrased 
thus, ‘Experience is the best way to learn.' All of the experimental 
evidence from educational psychology tends to substantiate this concept... 
Student participation, either purely mental or a combination of physi- 
cal and mental, is the key to successful efficient learning! 

Hence in the construction of the proposed educational aid, it was 


mandatory that it permit direct student experience in the actual design 





of computer logic circuits. This would most profitably be done within 
a framework that would enable the student to construct a logic circuit 
in familiar form using standard symbology. Further experience would 
be obtained by allowing student control of the inputs to the construc- 
ted circuit and observation of the responses of the circuit to these 
inputs. The major emphasis being on student control of variables and 


analysis of results. 


B. SUMMARY OF PREVIOUS RESEARCH 

The above requirements posed by an investigation of the basic con- 
Siderations in the design of an effective educational aid when consid- 
ered together with the requirement for clarity and ease of use indicated 
@ graphical approach to the problem. The expression, "One picture is 
worth a thousand words" has been used (almost too) extensively to 
characterize the value of graphical display, but nonetheless underscores 
the impact of this means of presenting information. Additionally, the 
requirements for student interaction with and control of the learning 
aid strongly suggested that it could best be constructed by using a 
digital computer with graphical input and output capability. The com- 
puter would be programmed to accept and display student inputs, perform 
analysis on these inputs, and display the results of the student's cir- 
euiy design efforts. 

Hence the fields of computer graphics in general and computer-aided 
design in particular were investigated as a prelude to construction of 
the program. The term, "computer graphics," has been defined iref. 3 
as that set of computer techniques and applications wherein data is 
either presented or accepted by 2 computer in graphical form. Teoe 


puter-aided design" (CAD) as the name implies, specifies the use of a 





computer as an assistant in the design of some entity. While computer 
graphics is a general enough term to encompass all computer systems 
using graphical display, computer-aided design usually implies a sig- 
nificant degree of man-computer interaction in the symbiotic relation- 
ship perceived by Licklider ref. hl. The designer specifies his ideas 
to the computer in graphical form, uses the computer's significant com- 
putational ability to perform some analysis of the design, possibly 
modifying the design for re-analysis. While the purpose of the proposed 
program did not include its specific use as a design aid for actually 
fabricating logic circuits, it was felt that the computer-aided design 
approach would be most successful in exposing the student to design 
concepts as applied to logic circuits. 

1. Computer-Aided Design (CAD) 

Early research in the field of computer-aided design centered 
at the Massachusetts Institute of Technology. Professor Steven A. Coons 
of the mechanical engineering department at that institution published 
@ paper in the early 1960's outlining the requirements for a computer- 
aided design (CAD) system ref. ae The paper traced CAD development 
from its genesis in the Automatic Programmed Tool System to the level of 
sophistication displayed by Sutherland's SKETCHPAD [ref. 6]. 

In examination of the design process itself, Coons saw "a few 
engineers performing highly creative tasks at the beginning, coupled 
with a very large number of draftsmen and technicians, who perform re- 
latively uncreative tasks over a fairly long period of time." [Ss | He 
further envisioned that this process could be vastly improved by using 
a computer with a graphical capability to accept, interpret, and remem- 


ber shape descriptive information. Additionally, the computer system 
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must have the ability to perform the mathematical analysis necessary to 
evaluate the design with respect to predetermined objectives. 
In support of his vision of improvement in the design process 
by computer, Coons enumerated several CAD system benefits: 
1) Emphasis on interaction and inter-communication between 
design users. 
2) Dynamic display of time-varying systems. 
3) Use of more accurate mathematical models, allowed by in- 
creased computational power. 
4) Exponential design rate, with subelements of design saved 
by computer. 
5) Use of the same basic structure by different design dis- 
ciplines. 
No discussion of computer graphics or computer-aided design 
would be complete without reference to the pioneering work of I. E. 
Sutherland, also at MIT. The SKETCHPAD system 6 | Was the tirsb. bo 
demonstrate the effective use of an interactive display console to ac- 
cept inputs and display outputs in graphical form and control the se- 
quence of program execution. Sutherland's program was built around a 
powerful data structure which allowed for representation of display 
elements, labeling of various parts of the display with alphanumerics, 
and representation of display topology. Analysis was accomplished in 
the program by the use of mathematical conditions (called "constraints,") 
on parts of the drawing. The addition of design constraints as well as 
geometrical constraints gave SKETCHPAD a significant design capability, 
although at the time of publication, Sutherland's program had not demon- 


strated the ability to design electrical circuits. 





C meolr cull Desten Programs 


The view of the nature of the problem as a logic circuit design 
task indicated a review of extant computer programs constructed for this 
purpose. Some examples of user-oriented circuit analysis programs re- 
viewed were Electronic Circuit Analysis Program (ECAP) ref. 7| and 
Continuous Systems Modeling Program (CSMP) ref. 8 | both IBM circuit 
analysis applications. Also investigated were Automated Engineering 
Design of Networks (AEDNET) [ref. 9 | and Circuit Analysis (CIRCAL) 

[ref. 10] by J. Katzenelson and M. L. Dertouzos respectively of MIT. 
Or ane pertinence to the construction of the logic demonstrator was 
Dertouzos's paper, "Introduction to On-Line Circuit Design." [ ref. jae 

In this paper, Dertouzos characterized on-line circuit design 
as a design dialog with short interaction delays. He further listed 
various requirements which must be met if the implementation of a cir- 
cuit design program is to be truly interactive. These include: 

1) An editing requirement to accomplish inputting of informa- 
tion such as network description, element description, vari- 
able values, etc. 

2) An output requirement to convert computer generated informa- 
tion into a form suitable for transmission to the user. 

3) <A definitional requirement to enable users to build sub- 
elements of a circuit design to be used in later more com- 
plex cl Rreulls. 

4) An informational requirement to provide the system with 
necessary control information to execute the program. 

5) A diagnostic requirement to enable the user to discover 


mistakes in his use of the program or design. 





im reference 11, Dertouzos also discussed an detail the intver- 
nal structure of on-line programs for circuit design emphasizing the 
need for storing of information and insuring proper information flow 
between various program segments. The importance of a comprehensive 
data structure capable of representing the topology of the network was 
presented along with the benefits of such a data structure. These 
aac lude : 

1) Efficient use of storage. 

2) Efficient application of algorithms. 

3) Use of operators which are independent of the size and 

structure of stored information. 

4) Efficient representation and processing of recursive 

constructs. 

The analysis portion of a typical on-line circuit design pro- 
gram was considered in light of the requirements for interaction, such 
as premature termination of the analysis by the ieee or changes in 
the course of the analysis designated by the designer. The nature of 
the on-line approach to circuit design was shown to be an adaptive type 
of process as opposed to one with predetermined structure. 

3. Circal: An On-Line Circuit Design Program 

The above requirements for a circuit design program were met in 
the CIRCAL program implemented at MIT by Dertouzos Gell: Several facets 
of the program applied directly to the development of the proposed log- 
lcal design program. The program itself had three distinct versions 
(CIRCAL-O, CIRCAL-1, CIRCAL-2), each capable of handling an increasingly 
complex electrical network. The program operated on-line on a modified 
IBM 7094 under the Project MAC system using either graphical or teletype 
modes. Of special interest were the use of a grid mesh, superimposed on 
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the display, with the restriction that circuit elements could lie only 
on the grid intersections. Connection of individual circuit elements 
was done using analysis of typewritten commands. 

In consideration of the interactional requirements listed above, 
the program was structured into three main segments. These were: 

1) <A DEFINE mode for circuit elements and waveforms. 

2) An INPUT/EDIT mode for forming or changing network connec- 

tions and specifying element values. 

3) A TEST/OUTPUT mode for observing response of the designed 

circuit to the specified inputs. 

Consideration was given to the importance of the data structure 
and analysis methods in the overall effectiveness of the system. Also 
of importance was the observation that "the 'input/edit' and 'define' 
functions of any on-line circuit design system are in principle inde- 
pendent of the methods used for network analysis." lio). 

4. Computer-Assisted Instruction (CAT) 

In view of the didactic nature of the proposed program, an in- 
vestigation of the field of computer-assisted instruction was deemed 
appropriate. Computer-assisted instruction evolved from the concept of 
programmed instruction first articulated by S. L. Pressey at Ohio State 
University in the 1920's. This learner-centered method of instruction 
presents new information to the student in the form of incremental steps 
with constant review and testing to reinforce learning. The method did 
not earn general acceptance until the need for reinforcement in learn- 
ing was underscored by the research of B. F. Skinner at Harvard Univer- 


sity in the middle 1950's. [ref. 12]. 


Why 





G. M. and L. C. Silvern [ref. 13] listed the criteria governing 
programmed instruction which are now generally accepted as: 

1) Instruction is provided without the presence of a human 

instructor. 

2) The learner progresses at his own rate (conventional group 
instruction, films, television and other fixed-format media 
do not satisfy this criterion.) 

3) Instruction is presented in small incremental steps requir- 
ing frequent response by the learner. 

4) There is a participative, overt interaction or two-way 
communication between learner and instructional program. 

5) Learner receives immediate feedback informing him of his 
progress. 

6) Reinforcement is used to strengthen learning. 

Although the methods of programmed instruction were unusually 
well suited for computer implementation, their appearance before the 
general availability of computers to educational institutions lead to 
initial textual implementation. The original structure of a programmed 
instructional text was essentially linear in nature. The student was 
presented an increment of information then tested on the concept in- 
volved. If the student responded incorrectly, he was given a simpli- 
fied and expanded version of the same information and allowed to proceed. 
More advanced programmed instruction methods soon developed with a 
branching structure capable of allowing brighter students to progress at 
a faster rate and tailoring the remedial information to the mistaken 


response given. 





Computer-assisted instruction then implies the implementation of 
programmed instructional concepts on a digital computer. The interac- 
tion, feedback, and reinforcement specified above make an interactive 
graphical approach especially well suited to computer-assisted 


is eruclLon. 


* 


5. Basic Logical Design 
By far, the oldest area of interest to the proposed project was 


that of logical design. In 185) George Boole, an English mathematician, 


published his classic book: An Investigation of the Laws of Thought on 
Which Are Founded the Mathematical Theory of Logic and Probabilities. 


Proceeding from his basic investigation of classical logic, Boole de- 
rived a "logical algebra" which today bears his name. 

The ability of boolean algebra to adequately describe the be- 
havior of relay switching circuits was first recognized by C. W. Shannon, 
also of MIT. In his Masters Thesis: "A Symbolic Analysis of Relay and 
OWwitching Circuits," ref. 1h] Shannon showed that any circuit consist- 
ing of combinations of switches and relays could be represented by a 
set of mathematical expressions. He further showed that these expres- 
sions were exactly equivalent to the algebra derived by Boole in the 
field of symbolic logic. Thus boolean algebra finds much application 
in the design of digital computer systems composed of storage elements 
and their associated circuitry for switching from one state to another. 

Boolean algebra differs from ordinary algebra in some fundamen- 
tal ways. As in ordinary algebra, letters are used as terms in boolean 
expressions but their meaning is different. Boolean variables can take 
on only two distinct values (usually represented by the binary numbers 


O and 1). Thus boolean variables are useful for depicting the existence 
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or non-existence of a given condition, such as a switch being open or 
closed or a statement being true or false. Boolean functions may be 
formed by using a number of different operators. However, all of these 
operators are derivable from sets of primitive boolean operators. One 
commonly known set consists of intersection (AND), union (OR), and 
negation (NOT). 

At the basic level taught in an introductory course, logical 
design involves the use of boolean primitives to describe information 
flow in a digital computer. Additionally, since a digital computer is 
a finite state machine, information storage requirements mist be con- 
sidered. Temporary storage (registers) or permanent storage (core) is 
accomplished in a computer by some type of bi-stable device. For design 
applications, register storage is usually of most interest and is accom- 
plished by means of a flip-flop (bi-stable mltivibrator ). 

Implicit in the assumption of a binary storage element is the 
ability for this element to be able to change state. Hence the value 
of Shannon's thesis is the ability to describe the conditions necessary 
for the switching of element states in boolean terms. The types of 
flip-flops thought to be of most application in a basic logical design 
course were the clear-set flip-flop, clear-set-trigger flip-flop and 
J-K flip-flop. State diagrams for these various flip-flops as well as 
truth-table representations of the boolean primitives AND and OR are 


found in the Appendix. 
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TIT. PROGRAM IMPLEMENTATION 


A. COMPUTER SELECTION 

With the above background information reviewed and under the assump- 
tion that an interactive learning aid for the design of basic computer 
circuits would be of value in the instruction of Naval Postgraduate 
School students, the actual construction of the program began. Of pri- 
mary concern was the selection of the computer installation upon which 
to implement the program. Prior statements emphasizing the need for 
interaction and graphical display inherent in the problem narrowed the 
choice to the Xerox Data Systems 9300/Adage Graphics Terminal - 10 
(AGT-10) system in the Naval Postgraduate School Computer Laboratory. 
It was felt that in achieving "minimal interference with other computer 
users", the logic design program would be best implemented on the AGT-10 
system using this system's "stand alone" capability. 

The main consideration in the selection of this computer facility 
was the significant ability of the Adage Graphics terminal to be pro- 
grammed for an interactive instructional application. The graphical 
display capability of this equipment, coupled with the interfaced user 
communication devices provided an ideal research vehicle for this com- 
puter graphics task. However, this is not proposed as a cost-effective 
way to build a learning aid. 

A large, fast processor (XDS 9300) capable of accepting higher 
level language programs, tied to a separate smaller computer (AGT-10) 
responsible for the graphical display was a concept used in many of the 


circuit design implementations cited above. However, in view of the 





program's proposed use as a learning aid, it was felt the increased 
availability of the program to potential users offered by "stand alone” 
implementation would be of value in earning student acceptance of the 
program. 

The "stand alone" capability of the AGT-10 is available by virtue 
of the fact that the Adage graphics unit has its own processor. The 
graphics facility provided by the AGT-10 system is comprised of a high 
speed, high precision vector generator with cathode ray tube (CRT) dis- 
play ref. 15]. The CRT has a 12 by 12 inch display area, with a small- 
er area of high resolution. A stroke-type character generator is also 
available for CRT display of alphanumerics. The graphics console of 
the AGT system has additional devices incorporated which facilitate 
graphical communication with the user. Devices of special interest to 
this program were the function switch box, light pen and alphanumeric 
keyboard. 

The DPR-2 Digital PRocessor associated with the Adage Graphics 
Terminal system is a general purpose digital computer with extensive 
transfer logic and addressing capabilities. The processor has a 30 bit 
word length, memory cycle time of two microseconds and 8 K memory size. 
Additional random-access memory is provided by the DMS-2 Disk Memory 
Subsystem. 

The main software support for the AGT-10 system is the Adage Extend- 
able Program Translator (ADEPT). ADEPT is an open-ended string substi- 
tution macro translator capable of producing relocatable machine language 
code. Two passes of the source language (ATEXT) are made to allow un- 
limited forward references to symbolic addresses. Other features of 


EaeeoDeEPT translator are: 
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1) Automatic definition of location symbols. 

2) Parameter assignment statements. 

3) Macro nesting capability. 

lh) Conditional translator capability. 

5) Definite and indefinite repeat statements. 

A unique feature of ADEPT allows definition of "action operators" 
in addition to those already present in the ADEPT translator; thus 


allowing the programmer to extend the language to his own needs. 


B. FLOW - OF - CONTROL 

Preliminary to the actual coding of the program in the ADEPT lan- 
guage, a consideration of overall program flow of control and data 
structure was undertaken. It was decided to divide the program into 
three main modes (as in CIRCAL). These were DEFINE, CONNECT, and 
ANALYZE. Student specification of the circuit, selection of analysis, 
and observation of circuit response to specified input values would be 
accomplished within this main framework. In addition, a brief instruc- 
tional mode would be provided within which the student would be shown 
necessary information to operate the program. A more expanded instruc-~ 
tional mode would display various basic logic circuits with inputs 
specified and outputs displayed with instructive comments. Program 
flow of control would allow the student to specify various inputs to a 
particular circuit and observe its response, change the circuit struc- 
ture by addition or deletion of circuit elements, or change the inter- 
connection of these elements. The instructional modes would be capable 
of selection from any point in the program and were intended to be com- 
prehensive enough to allow the student to operate the program without 


any additional instruction. 
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C. DATA STRUCTURE 

Of upmost concern at the outset was the selection of a data structure 
which was sufficiently powerful to represent the display structure and 
topological structure of a logic circuit, yet was capable of straight- 
forward implementation at the relatively low programming level of the 
ADEPT language. In most of the circuit analysis programs reviewed, the 
data structure used was some type of ring structure, involving a com- 
plex system of pointers. The complete ring structure requires having 
pointers from each data item to the preceeding and following item. Un- 
like a list, the structure is closed by also having pointers between 
the first and last data items. The inherent advantages of this type of 
structure are ease in searching for data items and the ability to re- 
present multidimensional concepts wherein one data item is a member of 
more than one ring. Connectivity relations, set membership, and termi- 
nal node identifications are especially well represented in this manner. 
This concept was implemented by Sutherland in his "generic" data struc- 
ture which grouped elements of the drawing by common properties [6 |. 

While the ring data structure has these circuits representation 
benefits, it also creates implementation problems in an assembly level 
language such as ADEPT. In order to handle the more sophisticated 
structure, many primitive operations on the structure itself mst be 


programmed at the machine level whereas this is not a requirement if a 


id 


' 


higher level language is used ref. Ta 

Much recent work in the area of computer data structures has pre- 
ceeded from the basic foundations of graph theory. Robin Williams 
lref. ive has shown the advantages of the graph theory approach to pre- 


serve the relationships and logical associations that exist among data 
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items in a computer program. One such approach involves the use of a 
bipartite graph. The bipartite graph consisting of two distinct types 
of vertices (in this case inputs and outputs) is especially well suited 
for representation of logic circuits. This graph has been defined 

[ ref. 18 | as one whose vertices can be partitioned into two disjoint 
sets in such a way that every edge has its first end point in one set 


of vertices and the other end point in the remaining vertex set. 
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A Bipartite Graph 


The circuit representation advantage offered by this approach to the 
data structure is that each gate may be considered as the intersection 
ef two distinct types of pointers. Thus, the circuit is completely re- 
presented at each element by a set of pointers for inputs and one for 


outputs. 
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Graph Theory and Data Structure 
Representation of an Arbitary Circuit Element 


Another benefit of this method of representing circuits is that it does 
not pose a limit on the number of inputs or outputs which may be con- 


nected to any specific gate. 
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FIGURE 3 


AND Gate with n Inputs 


It was decided to use the bipartite graph method of circuit repre- 
sentation in the computer program. However, the problem of depicting 
this structure at the ADEPT level remained. Thus an older means of 
representing data structure was implemented involving establishment of 
table structures in contiguous areas of memory. Since the number of 
circuit nodes the program was designed to handle was limited, these 


tables could be made a fixed length. Pointer structure was implemented 
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at the table level in that the head item in a data table pointed to the 
last item and vice versa, but internal pointers within each table were 
not present. These were represented by the contiguity of the table. 

The pointers representing the edges of the bipartite graph were placed 
in these tables as were the X,Y coordinates representing circuit element 
location. 

This model of the topology of the circuit consisting of direct 
access data sets in fixed length blocks has several benefits. It is 
extremely economic in its use of storage, data access time is short and 
the capacity of the tables can be easily increased. An additional ben- 
efit brought to light by this implementation is that display tables can 
be "preloaded" with display control instructions. This is especially 
important in the display of character information for establishing size, 


brightness, and italics control information. 


D. MAIN PROGRAM ROUTINES 

The INTERACTIVE LOGIC LABORATORY is composed of five distinct ADEPT 
programs designed to accomplish the objectives discussed above. The 
separate relocatable versions of these programs are linked together at 
execution time along with system routines FIN (for checking function 


switches) and AMRMX (for teletype interface). The five programs are 


| 


hierarchically related as follows: The main program called LIL is re- 
sponsible for displaying all of the user-entered and program-generated 
information. LIL calls four subordinate routines: LOGMM, CONCT, ANALR 
and INTRO based on the output of the user's light pen. LIL enables 
this instrument for "hits" on the text words DEFINE, CONNECT, ANALYZE 


and INTRODUCTION and branches to the appropriate subprogram. Thus, LIL 





is also responsible for the overall flow of control as specified by the 





LSEe?r . 


2) 





1. Define Mode 

The ADEPT program LOGMM accomplishes the circuit element defini- 
tion objective. LOGMM creates the display of the logic circuit by allow- 
ing the user to draw AND gates, OR gates, inverters and flip-flops on a 
5 by 5 grid displayed on the CRT. (Only the intersections of the grid 
which represent possible circuit node locations are drawn as dots). 
"menu" of available circuit elements is displayed at the bottom of th 
presentation and each menu item is labeled with the appropriate function 


Switch which will cause a copy of that element to be drawn. 
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"Menu" Display 


Actual circuit construction is accomplished by the user with the light 
pen. This instrument is used to select the dot where the circuit ele- 
ment 1s desired. Selection is indicated by the appearance of a square 
cursor around the dot. Depressing one of the appropriately labeled 

function switches chosen from the menu causes an instance of that cir- 


cuit element to be entered into the programs display table called TBLO. 
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Intering Circuit Elements in DEFINE Mode 


X and Y display coordinates are entered into the display table along 
with types of gate in the following format: 


bit 
os, Se eee oe ESS tee ep tee OAs 
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X display coordinate O}; Y display coordinate type 
(15 bits) is (12 bits) (2 bats) 







ee oe me 


FIGURE 6 


[BLO Table Entry 


tie top entry in the TBLO Table is a pointer to the last entry in the 
table. The end-of-list bit (abbreviated EOL above) is not used. The 


gate types are entered according to the following table: 


Z0 





SS = 


000--not used 
001--AND gate 
010--OR gate 
Ol1--inverter 
100--clear-set flip-flop 
101--toggle flip-flop 
110--J-K flip flop 
111--not used 

TABLE 1 


Gate Types Entered in TBLO 


Removal of a circuit element is accomplished by selecting an exist- 
ing element with the light pen (a similar cursor indication notifies 
user of selection). This is accomplished by removing the erased entry 
from the TBLO table and moving all subsequent TBLO entries up one loca- 
tion. The pointer to the last entry is adjusted to point to the new 
last entry in the table. Upon exit the program returns to the main 
display mode. 

2. Connect Mode 

The program CONCT establishes the topological structure of the 
circuit. Its major function is to build the display table for the 
Connecting lines between circuit elements previously entered in the 
DEFINE mode. Function switches are implemented in this mode for moving 
the cursor and for drawing lines to represent the circuit connections. 
The created lines are entered into a display data set called DATA! and 
refreshed continually. Additional function switches allow the user to 
select any point on the screen to which he has previously moved the 
cursor. The points may be selected in the ordered entered (select for- 
ward) or in reverse order (select backward). This feature aids the 
user in "hooking" a line for subsequent erasure from the data set or in 


positioning the cursor exactly on a point previously moved to or drawn. 


of 





—— a 


Terminal connections of the circuit are drawn in the usual schematic 
manner. Data entered in DATA! table is of the same format as the 


normal 30-bit Adage display word. 


bit 
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FIGURE 7 


DATA] Table Entry 


The end-of-list bit (EOL) is present to one in all table entries. The 
remaining bits in the DATA1 table are zeroed. When the user enters a 
"move" or "draw" command via the function switches in the CONNECT mode 
the display coordinates of the cursor are stored in the next DATA] entry. 
The EOL bit is cleared and the move-draw bit (abbreviated M/D above) is 
set if the command was a "draw". When this information is displayed, 
the presence of an end-of-list bit following the last DATA] entry is 
assured. The DATA] data set thus is drawn as one contiguous set of 
display commands. 
3. Analysis Mode 

The program ANALR performs analysis of the drawn circuit in two 
ways. Upon entering ANALR for the first time, the display tables of 
circuit elements created in the DEFINE mode and circuit connections 
entered in CONNECT are examined to determine the topology of the network. 

This is accomplished by creating a bipartite graph with circuit 
element inputs and outputs considered as the vertices of NG See and 


pointers representing edges. The results of this analysis are stored in 
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other memory tables to be used subsequently in calculating circuit re- 
sponse to specified inputs. 
a. Circuit Analysis 

The topological analysis rests on this assumption: Any cir- 
cuit element (or terminal node) which is connected to another element 
will have a line (or lines) representing this connection in the data 
set created in CONCT. 

Thus, the first analysis task is to determine the end points 
of the connections entered. This is done by searching the DATA] table 
for an instance of a "move" entry. The assumption is made that this 
"move'' entry indicates the user is about to draw a sequence of lines 
representing a circuit connection. The significance of the "move" en- 
try is that the X,Y position of the "move" will be the location of the 
initial point of the connection. Hence the X,Y position identified as 
a "move" is placed into a table called RAWBK. The succeeding DATAI 
entries are searched until the next "move" entry is found-indicating a 
new connection sequence has begun. The X,Y position of the immediately 
preceeding entry in the table is then recorded as the termination of 
the connection established by the original "move". This X,Y position 
is then entered into the next position in the RAWBK table. The above 
process continues until the entire DATA] table has been searched. 
Special care is exercised to ensure that extraneous moves inadvertently 
entered by the user, or erased entries do not affect the extraction of 


Popolopically correct line end points. 
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Relationship of DATA1 and RAWBK Data Tables 


The format of the entries in the RAWBK table is exactly the same as that 
of DATAl. The difference is that the RAWBK table contains only those en- 
tries in DATA] which represent the end points of connections. Thus the 
RAWBK table is a compression of the topological information contained in 
the DATA] display table. 

Once the RAWBK table has been built, the basic information 
required for topological analysis of the circuit is present. The actual 
construction of the bipartite graph begins by establishing a circuit 
Scanning loop. In this loop, each column of the grid is searched pro- 
ceeding from the left to the right side of the CRT. This is done 
assigning an X coordinate value to the variable "level" which will be 
greater than any X value of a circuit termination point connected to a 
circuit element in that column of the grid. However, the "level" value 
is less than the X value of an entry in the next grid colum. 

All termination points entered in RAWBK which have X values 
to the left of this level will be mapped into one of three tables. If 


the display coordinates of a termination point fall within the limits 
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which allow a point to be connected to a gate, a determination is made 
whether this point should be considered as an input or output to this 
element. This decision is based on the side of the gate to which the 
point is connected. If a RAWBK entry falls within the X,Y constraints 
and is an input, a corresponding entry is made in the BAND (Basic ANalysis 
Data) table. Outputs are similarly entered into the BANDO (Basic ANalysis 
Data, Outputs). 
bit 
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BAND Table Intry 
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BANDO Table Entry 


The field labeled * above represents a three bit value corresponding to 
the height of this input (or output) on the gate. This information must 
be extracted for use in the analysis of sequential elements. 

Any RAWBK entry whose X value is to the left of the level 
value but does not map into a circuit element is placed in the unresolved 
(URD) table. (Note that all circuit inputs and outputs will generate an 
URD entry as one of the end points of each of these lines is not connected 
to a gate). The form of the unresolved data (URD) table is the same as 
that of RAWBK: An X,Y display coordinate value. The coordinates entered 


into Inputs/Outputs table (BAND/BANDO) are compressed to allow room in 
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the word for the gate type and connection pointer determined by this 
phase of ANALR. The X,Y coordinate values entered are the two most sig- 
nificant (Octal) digits of the display coordinate of the circuit element 
entries in the TBLO table. This was done because the X,Y values of the 
defined entries in TBLO are fixed by grid position whereas the RAWBK X 
(and Y) entries can vary significantly depending on the width (or height) 
of the circuit element. Four digits representing X,Y position together 
with one digit representing the type of gate are thus extracted from 

the TBLO entry and packed into one half word of the Inputs/Outputs 
table. The pointer half word contains the RAWBK address of the other 
end point of this connection. To make explicit the bipartite graph im- 
plication of the pointer, a BAND entry has its pointer in the lower half 
word (telling where this input goes) and BANDO entry pointers are in the 
upper half word (telling where this output comes from). 

In addition to the URD (Unresolved) table, which contains 
the display coordinates of inputs and outputs in a full 30 bit word, the 
unresolved entries in RAWBK are used to create another table called "Un- 
Resolved Inputs/outputs" (URI). Each entry in the URI table consists of 
two pointers. The pointer in the top half word designates the display 
coordinates of this unresolved entry (i.e. a pointer into the URD table). 
The lower half word is a pointer to the memory location in the ANSW 
(answers) table reserved for the actual binary value of the input (or 
output) which will be specified (or calculated) later in the program. 
This table is required to enable user specified inputs to be placed into 
the proper ANSW (answer) location. Complete topological analysis is 


thus attained by repeating the above procedure for each grid colum. 


Bye 
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URI Table Entry 


b. User Input 

The entire connection analysis outlined above is transparent 
to the user. After its completion, ANALR (Analysis Program) automatically 
enters a specification phase. Two additional kinds of information are 
needed before circuit response can be calculated. The first of these 
is the labeling of terminal nodes of the circuit with up to 3 alpha- 
numeric characters to enable a logic equation representing the circuit 
to be constructed. Once nodes have been labeled, actual binary inputs 
are accepted for each input preparatory to calculating circuit response. 
The node labeling phase is especially important pees this is where 
the user will be notified of an improper circuit connection if one exists. 
Any entry (not a circuit input or output) which was not properly connec- 
ted by CONCT will be pointed out for labeling. Hence, if the program 
asks for a label where the user can see that one is not required, the 
circuit must be re-connected. 

The user is allowed to label the circuit with up to three 
alphanumeric characters at each circuit input and output. These charac- 
ters are accepted and processed by ANALR (Analysis Program) and con- 
verted into display form for subSequent drawing on the cathode ray tube 
by LIL (main display mode ). In order to do this, a foreground/back- 


ground type of operation is set up between LIL and ANALR which allows 
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the continual display of already entered circuit information while wait- 
ing for teletype inputs of alphanumerics for subsequent display. The 
binary values input to the circuit are then accepted and processed in a 
Similar manner. All character display information is stored in one of 
two tables: CTAB for label display data and NTAB for value display data. 


The structure of each of the tables is exactly the same. 
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The abbreviation AN above is for Alphanumeric character field, capable 
of storing one ASCII (American Standard Code for Information Inter- 
change) code display character. 
Ce Circuit Response 

The response of the circuit to specified inputs is then de- 
termined. Another table called ANSW is reserved in memory for holding 
the binary numbers input,and output values at any point in the circuit. 
Data representing both is indexed into this table by the last two digits 
of the RAWBK pointer in the corresponding BAND or BANDO entry, thus 


guaranteeing a unique storage address for each input and output value. 


3h 
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Another table reserved in memory is FFDT (Flip-Flop Data 

Table). This table is actually built upon exit from the DEFINE mode. 
One entry is made in this table for each flip-flop entered in DEFINE. 
The format of the entries is the same as the standard Adage display 
word: A 1h bit display X value, a 1) bit display Y value and end-of-list 
bits in bits 1) and 29 of the display word. The EOL bit in bit position 
1h is used as an undefined flag (as in ANSW above). The EOL at bit posi- 
tion 29 contains the current state of the flip-flop: (set-1, reset-0O). 
The undefined flag will be set when the state of the flip-flop cannot 
be calculated from current inputs. 

| Actual response calculation is done using a memory stack. 
The STACK is loaded from the top down with the binary values from ANSW 
which represent the inputs to the gate being simulated. A subroutine 
call is made to one of six subroutines to simulate the response of the 
circuit element to these inputs. The subroutine call is based on the 
gate type [ Table |. 

The subroutine operates on all the stack values and places 
the binary result on top of the stack. Upon return to the main analysis 
program, this value is stored into the appropriate memory location in 
ANSW (answers). If the circuit element being simulated is a flip-flop 


some additional work must be done. Before the call to the appropriate 
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simulation subroutine the last state of the flip-flop mst be obtained 
from the FFDT (Flip-Flop Data Table). This is stored at the location 
STACK-1 and is used to calculate the response of the flip-flop to the 
current input based on the last state. Upon return from the subroutine 
the current state of the flip-flop is entered into the appropriate FFDT 
tocation. 

Circuit response calculation is carried out from left to 
right according to the following algorithm. 

1) Locate the first (or next) circuit element in the BAND 

table. 

2) Find the binary value in ANSW (specified by this BAND 
entry) and load this value into the stack. 

3) Find all other inputs to this gate in BAND and load 
their values into the stack. 

4) Calculate response of this gate by a jump to the appro- 
priate subroutine as specified by type of gate. 

5) Locate each instance of this gate in the output (BANDO) 
table and stuff the calculated value into the ANSW 
address specified by this entry. 

6) If this is the last circuit element stop, if not go to 
step 1. 

Once the response of the complete circuit has been calcu- 
lated, the answers must be displayed to the user. This is done by con- 
verting the binary value in each location in ANSW corresponding to a 
circuit output into display form and entering it into the number display 


table. 
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After displaying the results of the calculation ANALR returns 
to the "INPUT VALUES" mode to allow the circuit to be tested with other 
input values. A new circuit may be constructed (or the current one modi- 


fied) by leaving the analysis mode via the "MODE EXIT" function switch. 
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A. SAMPLE TERMINAL SESSION 
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FIGURE 1 


Initial Command Presentation 


Selection of INTRODUCTION would display to the user a comprehensive 
explanation of the program and how to use it. 
In this example case the DEFINE mode was selected with the light 


pen and the basic circuit elements of the half-adder were entered. It 


was desired to design the half-adder according to the above mentioned 


exclusive-or representation, hence two inverters, two AND gates and an 
OR gate were entered a hown by 1 fe jing dls} in the DEFIN 


mode: 
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DEFINE Mode Display 


After exiting the DEFINE mode Which created the above display) via 
the function switches the CONNECT mode was selected from the command menu 
of the main display mode. Connections were then established by moving 
the cursor with the appropriate function switches. A typical CONNECT 


View is shown in the following scope photograph: 
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ANALYSIS Mode--Numeric Input Phase 


Ss previously mentioned any circuit. element whose connection is not 


properly specified upon initial entry into this phase of the program 
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Will be pointed out for labeling. When th abeling process 1S comp.eted 
the program automatically enters the response calculation mode, wherein 
the user's binary teletype inputs are accepted and processed for each 
circuit input. The appropriate routines are called to simulate tl -ir- 
Pry and the result of the response calculation 1S converted into display 


mom and is shown for this particular circuit in the following picture: 
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A reset pulse clears the flip-flop to zero (Lower left flip-flop). 
Finally the flip-flop's response to an illegal combination of inputs 


is shown. 


Be RESULTS 

At the current stage of program development the INTERACTIVE LOGIC 
LABORATORY has demonstrated significant ability to enable the user to 
create and analyze basic logic circuits. The program has not yet been 
used by beginning students in logical design. However, several features 
of the implementation should allow its eventual use as an adjunct to the 
classroom instruction received in the "Logical Design of Digital Compu- 
ters" course (CS-3200) taught at the Naval Postgraduate School. 

1) Although no generally accepted set of symbols exists for 
representing logic elements, the symbols used are universally 
identifiable since the specified operation is shown in the 
logic display symbol. 

2) The sequential elements (flip-flops) are not standard symbols, 
but are quite recognizably presented. 

3) The degree of student control achieved by the implementation 
allows the student to proceed at his own rate in the design of 
baste Opie sciureus. 

4) The level of description of the INTRODUCTION mode is sufficient- 
ly comprehensive to allow most students to use the program with 
no assistance. Additionally, the fact that this mode does not 
have to be selected and only part of the instructions may be 
reviewed does not subject the student to tedious repetition of 


instructions as he gains proficiency in the use of the program. 





Implementation of sequential circuits has met with less success. 
At the current stage of development the INTERACTIVE LOGIC LABORATORY 
can not be used for the design of sequential circuits. However, indi- 
vidual flip-flops are simulated correctly thus allowing the student to 


observe the response of individual elements to various inputs. 


C. EXTENSIONS 

Two basic inadequacies exist in the program. First of all, the bi- 
partite graph representation does not allow any feedback loops to be 
present in the circuit. Since this is not an uncommon occurrence in 
logic circuits, the program should be modified to allow the output from 
a circuit element to be delayed and re-input to the same element. 
Secondly, the program as currently implemented does not allow for re- 
cursive constructs, hence only circuits that will fit on the 5 by 5 grid 
may be constructed. It is felt that the bipartite data structure is 
general enough to handle larger circuits, wherein a previously analyzed 
circuit is reduced to be considered as another primitive element. 

Another area where extension of the current program is required is 
in the saving of a user's circuit design efforts and hard copy output. 
The saving of circuits could be done by punching out the display tables 
on paper tape. Then at a subsequent computer session the DATA! and 
TBLO tables could be read into the teletype unit allowing the user to 
continue where he previously stopped. Hard copy output which is in- 
telligible to the user is harder to obtain with the AGT-10, but the 
cheaper graphics terminals required for more general implementation of 


this program have provisions for hard copy output. 
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D. RECOMMENDATIONS AND CONCLUSIONS 

It is felt that INTERACTIVE LOGIC LABORATORY has shown the feasi- 
bility of using a computer graphics terminal to demonstrate the basic 
concepts of logical design. One of the severe drawbacks associated 
with this particular implementation is the high cost of the Adage 
Graphics Terminal. While this could be justified by the research in- 
tent of this program, any extension of the concepts of this program 
into general classroom use will necessitate a lower cost graphics 
terminal. 

Currently available storage tube graphics terminals meet these cost 
requirements. A classroom installation composed of individual cathode 
ray tubes for each student tied to a central computer capable of re- 
sponding to all users in a time-shared mode would be ideal for the im- 
plementation of this logic demonstrator. Such a classroom computer 
installation is now available and the implementation of the INTERACTIVE 
LOGIC LABORATORY on this equipment would indeed provide a meaningful 


laboratory for experimentation in basic logical design. 
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APPENDIX A 


Truth Table for 3-input gates AND OR 
A B C A.B.C A+B+C 
O O O O O 
O O 1 O 1 
O 1 O O 1 
O 1 1 O 1 
1 O O O 1 
1 O ] O 1 
1 ] O O ] 


Truth Table for clear-set flip-flop 


SET REOET INITIAL FINAL 
; OTATE OTATE 
O O O O 
O O 1 1 
O 1 O O 
O 1 1 O 
1 O O 1 
1 O 1 1 
1 1 0 ? (undefined ) 
1 1 1 ? (undefined) 
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APPENDIX A (continued) 


Truth Table for clear-set-toggle flip-flop 


SET TOGGLE RESET INITIAL FINAL 

STATE STATE 
e) e) QO 0 0 
e) e) 0 | 1 
e e) ] 0 e) 
O e) | 1 O 
0 1 0 0 1 
0 1 0 1 O 
0 1 1 O 2 
0 1 1 1 é 
1 0 QO 0 1 
1 0 O 1 1 
1 0 1 0 i 
1 0 | 1 : 
1 1 0 O fi 
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APPENDIX A (continued) 


Truth Table of J-K flip-flop 


J K INITIAL 
OTATE 

0 O 0 

O O 1 

O 1 O 

O 1 1 

1 O Q 
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